<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>

<body>
    <button>抽奖</button>
    <script>
        // 1. 封装一个获取随机数rand函数
        function rnd(n, m) {
            return Math.ceil(Math.random() * (m - n + 1)) + n - 1;
        }
        // 2. 获取按钮
        let btn = document.querySelector('button');
        // 3. 添加点击事件
        btn.onclick = function () {
            // 4. 创建一个promise实例
            let p = new Promise((res, rej) => {
                // 4.1 在执行器内设置1s单次定时器
                setTimeout(() => {
                // 4.2 调用rand()
                // 4.3 判断中奖与否 - 概率30%
                // 4.3.1 中奖调用resolve
                // 4.3.2 未中奖调用reject
                    let num = rnd(1, 100);
                    if (num <= 30) {
                        res(`中奖了,编号：${num}`)
                    } else {
                        rej(`未中奖,编号：${num}`)
                    }
                }, 1000);
            })
            // 5. 调用promise实例的then方法
            p.then(val => {
                console.log("恭喜你", val);
            }, rea => {
                console.log("很遗憾", rea);
            })
        }
    </script>
</body>

</html>